Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Correctly include lib64 library on manylinux archives #747

Merged
merged 2 commits into from
Sep 2, 2024

Conversation

mgautierfr
Copy link
Member

Manylinux build are based on Redhat and libs are put in /lib64 directory and not in /lib/<arch>/ as on Debian based build.

Fix #746

@mgautierfr mgautierfr requested a review from rgaudin September 1, 2024 08:24
Copy link
Member

@rgaudin rgaudin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@kelson42
Copy link
Contributor

kelson42 commented Sep 1, 2024

CI is red!

@mgautierfr
Copy link
Member Author

CI is red!

Kiwix server is down :)

@kelson42
Copy link
Contributor

kelson42 commented Sep 1, 2024

@mgautierfr fixed, but windows-mixed still fails

@mgautierfr
Copy link
Member Author

This is mostly broken because of kiwix/libkiwix#1116
I let you read the CI logs.

@kelson42
Copy link
Contributor

kelson42 commented Sep 2, 2024

@mgautierfr I have relaunched the CI this morning so it can benefit of latest nightly but this does not fix the problem. Not clear at all why the latest piece of code of libkiwix is not available OR maybe the version of libkiwix is not properly defined in14.0.0. In both cases, this is not clear where is the issue at this stage.

@rgaudin
Copy link
Member

rgaudin commented Sep 2, 2024

I see that both https://tmp.kiwix.org/ci/dev_preview/manylinux_archive/libzim_linux-x86_64-manylinux-2024-09-01.tar.gz does have the binary but it is in a lib64 sub-folder. Is this what we want?

I also see that https://tmp.kiwix.org/ci/dev_preview/manylinux_archive/libzim_linux-aarch64-manylinux-2024-09-01.tar.gz still doesn't include the binary.

@mgautierfr
Copy link
Member Author

libkiwix is properly defined to 14. This is other projects which are looking for kiwix <14.
With kiwix/kiwix-tools#700 and kiwix/kiwix-desktop#1192 just merged this should be good.

@mgautierfr
Copy link
Member Author

mgautierfr commented Sep 2, 2024

I see that both tmp.kiwix.org/ci/dev_preview/manylinux_archive/libzim_linux-x86_64-manylinux-2024-09-01.tar.gz does have the binary but it is in a lib64 sub-folder. Is this what we want?

I suppose too. manylinux is based on redhat and lib64 is where libraries goes on redhat. So I suppose that (in manylinux env at least) configuration is expecting that.

I also see that tmp.kiwix.org/ci/dev_preview/manylinux_archive/libzim_linux-aarch64-manylinux-2024-09-01.tar.gz still doesn't include the binary.

Will check
When cross compiling, we always put libraries in lib/<arch>.
New commit fix this (packaging, not where we put libraries)

@rgaudin
Copy link
Member

rgaudin commented Sep 2, 2024

I suppose too. manylinux is based on redhat and lib64 is where libraries goes on redhat. So I suppose that (in manylinux env at least) configuration is expecting that.

Except that those manylinux builds are not for redhat systems but for all older systems. Also, for aarch64, those wont be in lib64 because you cross-compile.

I am OK with the argument that “we simply copy what we have” though which is OK for most users. Automated tools like pylibzim will just have to rglob to find it.

Copy link
Member

@rgaudin rgaudin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍

@mgautierfr
Copy link
Member Author

What is recommendation from manylinux project ?
Or they don't care because they are about compiling and not packaging ?

Manylinux build are based on Redhat and libs are put in `/lib64`
directory and not in `/lib/<arch>/` as on Debian based build.

Fix #746
@rgaudin
Copy link
Member

rgaudin commented Sep 2, 2024

It's just a shell for compiling. The packaging part is up to the project. We copy the lib inside our package manually. Our system mode (where it would look for it inside /lib64 I believe is only tailored for not-including libzim in package.

Libkiwix update its version to 14.0.0 and we use the declared version in
`version.py` to select file to package and sign.
So we must be in sync.
@kelson42
Copy link
Contributor

kelson42 commented Sep 2, 2024

@mgautierfr I guess we can merge and make a new build?!

@mgautierfr mgautierfr merged commit 7e9cb8c into main Sep 2, 2024
44 checks passed
@mgautierfr mgautierfr deleted the manylinux_archive branch September 2, 2024 12:03
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

manylinux libzim release does not contain binary file
3 participants